// 导航守卫处理
import router from './router'
import store from './store'
// 进度条动画使用
import Nprogress from 'nprogress'
import 'nprogress/nprogress.css'

const pageArr = ['/404', '/login']
//

// 导航前置守卫
router.beforeEach(async(to, from, next) => {
  Nprogress.start()
  if (store.getters.token) {
    if (to.path.toLowerCase() === '/login') {
      next('/')
    } else {
      // 有token时去其他页面
      // 判断是否有用户信息
      if (!store.state.user.userInfo.userId) {
        await store.dispatch('user/getUserInfo')
      }
      next()
    }
  } else {
    // 白名单验证处理
    if (pageArr.includes(to.path.toLowerCase())) {
      next()
    } else {
      next(`/login?redirect=${encodeURIComponent(to.fullPath)}`) // 回调地址处理
    }
  }
  Nprogress.done()
})
// 导航后置守卫
router.afterEach((from, next) => {
  Nprogress.done()
})
